package simple.array;

/**
 * 169. 多数元素
 * 给定一个大小为 n 的数组，找到其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。
 * 你可以假设数组是非空的，并且给定的数组总是存在多数元素。
 * 示例 1：
 *   输入：[3,2,3]
 *   输出：3
 * 示例 2：
 *   输入：[2,2,1,1,1,2,2]
 *   输出：2
 * 进阶：尝试设计时间复杂度为 O(n)、空间复杂度为 O(1) 的算法解决此问题。
 * @author 刘学松
 * @date 2022-01-02 23:34
 */
public class 多数元素 {
    public int majorityElement(int[] nums) {
        int candidate = nums[0];
        int size = 1;
        for (int i = 1; i < nums.length; i++) {
            if (size == 0) {
                candidate = nums[i];
                size = 1;
            } else {
                if (nums[i] == candidate) {
                    ++size;
                } else {
                    --size;
                }
            }
        }
        return candidate;
    }
}
